<template>
    <div class="flex flex-col mb-2 flex-auto ns-media" :class="hasError ? 'has-error' : 'is-pristine'">
        <label :for="field.name" class="block leading-5 font-medium"><slot></slot></label>
        <div class="mt-1 relative border rounded-md focus:shadow-sm">
            <div v-if="leading" class="absolute inset-y-0 left-0 pl-3 flex items-center pointer-events-none">
                <span class="text-fontcolor sm:text-sm sm:leading-5">
                {{ leading }}
                </span>
            </div>
            <div class="rounded overflow-hidden flex">
                <div 
                    v-if="field.data && field.data.type === 'model'"
                    class="form-input flex w-full sm:text-sm items-center sm:leading-5 h-10">
                    <template v-if="field.value && field.data.model.name">
                        <img v-if="isImage( field.data.model )" class="w-8 h-8 m-1" :src="field.data.model.sizes.thumb" :alt="field.data.model.name">
                        <template v-if="! isImage( field.data.model )" class="object-cover" :alt="field.data.model.name">
                            <div class="object-cover flex items-center justify-center">
                                <i :class="fileIcons[ field.data.model.extension ] || fileIcons.unknown" class="las text-3xl"></i>
                            </div>
                        </template>
                        <span class="text-xs text-fontcolor-soft">{{ field.data.model.name }}</span>
                    </template>
                </div>
                <input 
                    v-if="! field.data || field.data.type === 'undefined' || field.data.type === 'url'"
                    v-model="field.value" 
                    :disabled="field.disabled"
                    @blur="$emit( 'blur', this )" 
                    @change="$emit( 'change', this )" 
                    :id="field.name" :type="type || field.type || 'text'" 
                    :class="inputClass" class="form-input block w-full sm:text-sm sm:leading-5 h-10" :placeholder="placeholder" />
                <button 
                    @click="toggleMedia( field )"
                    class="w-10 h-10 flex items-center justify-center border-l outline-hidden">
                    <i class="las la-photo-video"></i>
                </button>
            </div>
        </div>
        <ns-field-description :field="field"></ns-field-description>
    </div>
</template>
<script lang="ts">

import { Popup } from '~/libraries/popup';
import { default as nsMedia } from "~/pages/dashboard/ns-media.vue";
import { fileIcons } from '~/shared/file-icons';

export default {
    computed: {
        hasError() {
            if ( this.field.errors !== undefined && this.field.errors.length > 0 ) {
                return true;
            }
            return false;
        },
        disabledClass() {
            return this.field.disabled ? 'ns-disabled cursor-not-allowed' : '';
        },
        inputClass() {
            return this.disabledClass + ' ' + this.leadClass
        },
        leadClass() {
            return this.leading ? 'pl-8' : 'px-4';
        }
    },
    data() {
        return {
            fileIcons
        }
    },
    props: [ 'placeholder', 'leading', 'type', 'field' ],
    mounted() {
    },
    methods: {
        /**
         * Returns wether the provided media 
         * is an image or not.
         * @param {object} media 
         */
        isImage( media ) {
            const imageExtensions   =   Object.keys( ns.medias.imageMimes );
            return imageExtensions.includes( media.extension );
        },

        toggleMedia() {
            const promise   =   new Promise( ( resolve, reject ) => {
                Popup.show( nsMedia, { resolve, reject, ...( this.field.data || {} )});
            });

            promise.then( ( action: { event: string, value: any[] } ) => {
                /**
                 * When the performed action is "use-selected"
                 * we define the current field value with what has been selected (first entry)
                 * and we close the popup.
                 */
                if ( action.event === 'use-selected' ) {
                    /**
                     * a field might choose to use a URL 
                     * or to link to an existing model
                     */
                    if ( ( ! this.field.data || this.field.data.type === 'url' ) ) {
                        this.field.value    =   action.value[0].sizes.original;
                    } else if ( ( ! this.field.data || this.field.data.type === 'model' ) ) {
                        this.field.value        =   action.value[0].id;
                        this.field.data.model   =   action.value[0];
                    } else {
                        this.field.value        =   action.value[0].sizes.original;
                    }

                    this.$forceUpdate();
                }
            });
        }
    }
}
</script>